package com.yanhuo.xo.saToken;

import cn.dev33.satoken.stp.StpInterface;
import com.yanhuo.xo.dao.MenuMapper;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Component;

import java.util.ArrayList;
import java.util.List;

/**
 * 自定义权限验证接口扩展
 */
@Component    // 保证此类被SpringBoot扫描，完成Sa-Token的自定义权限验证扩展
@RequiredArgsConstructor
@Slf4j
public class StpInterfaceImpl implements StpInterface {

    private final MenuMapper menuMapper;

    /**
     * 返回一个账号所拥有的权限码集合
     */
    @Override
    public List<String> getPermissionList(Object loginId, String loginType) {

        if(loginId.equals("1")){
            return menuMapper.selectButtonPermissions(loginId.toString(),true);
        }
        List<String> str= menuMapper.selectButtonPermissions(loginId.toString(),false);
       log.info("校验权限了,权限集合："+str.toString());
          return   str;
    }

    /**
     * 返回一个账号所拥有的角色标识集合 (权限与角色可分开校验)
     */
    @Override
    public List<String> getRoleList(Object loginId, String loginType) {
        log.info("校验角色了");
        return new ArrayList<>(); // 从数据库查询这个账号id拥有的角色列表
    }
}
